<template>
  <el-dialog :title="businessTitle"
             :visible.sync="businessDialogVisible"
             width="600px"
             :before-close="businessClose">
    <div class="business-list">
      <div class="business-label">商机组名称</div>
      <el-input v-model="name"
                style="width: 60%;"></el-input>
    </div>
    <div class="business-list">
      <div class="business-label">应用部门</div>
      <el-select v-model="businessDep"
                 placeholder="请选择"
                 multiple
                 style="width: 60%;">
        <el-option v-for="item in optionsDep"
                   :key="item.id"
                   :label="item.label"
                   :value="item.id">
        </el-option>
      </el-select>
      <div class="business-des">默认全公司</div>
    </div>
    <div class="business-setting">
      <div>阶段设置</div>
      <div class="business-setting-content">
        <div class="business-setting-table-header">
          <span>阶段</span>
          <span>阶段名称</span>
          <span>赢单率</span>
        </div>
        <div class="business-setting-table-body">
          <div v-for="(item, index) in settingList"
               :key="index"
               class="business-setting-table">
            <span>{{'阶段' + (index+1)}}</span>
            <span>
              <el-input v-model="item.name"
                        size="mini"></el-input>
            </span>
            <span class="icon-span">
              <el-input v-model="item.rate"
                        @change="changeInput"
                        size="mini"
                        type="number"></el-input> %
              <span class="icon-box">
                <span @click="addIcon"
                      class="el-icon-circle-plus"></span>
                <span v-if="index != 0"
                      class="el-icon-remove"
                      @click="removeIcon(index)"></span>
              </span>
            </span>
          </div>
          <div class="business-setting-table">
            <span>结束</span>
            <span>赢单</span>
            <span>{{winSingle}} %</span>
          </div>
          <div class="business-setting-table">
            <span>结束</span>
            <span>输单</span>
            <span>{{loseSingle}} %</span>
          </div>
          <div class="business-setting-table">
            <span>结束</span>
            <span>无效</span>
            <span>{{invalidSingle}} %</span>
          </div>
        </div>
      </div>
    </div>
    <span slot="footer"
          class="dialog-footer">
      <el-button type="primary"
                 @click="businessSubmit">确 定</el-button>
      <el-button @click="businessClose">取 消</el-button>
    </span>
  </el-dialog>
</template>

<script>
import { depList } from '@/api/common'

export default {
  data() {
    return {
      optionsDep: [],
      businessDep: [],
      settingList: [],
      name: '',
      // 赢单
      winSingle: 100,
      loseSingle: 0,
      invalidSingle: 0
    }
  },
  props: {
    businessDialogVisible: Boolean,
    businessTitle: String,
    /** 编辑时候传递进来的信息 */
    infoData: {
      type: Object,
      default: () => {
        return {}
      }
    }
  },
  watch: {
    infoData: function(val) {
      this.name = val.name
      this.businessDep = val.businessDep.map((item, index) => {
        return item.id
      })
      this.settingList = val.settingList
      if (!this.settingList || this.settingList.length == 0) {
        this.settingList = [{ name: '', rate: '' }]
      }
    }
  },
  mounted() {
    depList().then(res => {
      this.optionsDep = res.data
    })
  },
  methods: {
    businessClose() {
      this.$emit('businessClose')
    },
    businessSubmit() {
      if (!this.name) {
        this.$message.error('请填写商机组名称')
      } else if (!this.businessDep) {
        this.$message.error('请关联应用部门')
      } else {
        var pass = true
        for (let index = 0; index < this.settingList.length; index++) {
          const item = this.settingList[index]
          if (!item.name || !item.rate) {
            pass = false
            this.$message.error('请完善阶段信息')
            break
          }
        }
        if (pass) {
          this.$emit(
            'businessSubmit',
            this.name,
            this.businessDep,
            this.settingList,
            this.businessTitle,
            this.infoData.typeId
          )
        }
      }
    },
    // 增加
    addIcon() {
      this.settingList.push({ name: '', rate: '' })
    },
    // 删除
    removeIcon(val) {
      this.settingList.splice(val, 1)
      this.changeInput()
    },
    // 赢单率
    changeInput(val, index) {
      // this.winSingle = 0
      // for (let item of this.settingList) {
      //     if (item.rate) {
      //         this.winSingle += parseInt(item.rate)
      //     }
      // }
      // if (this.winSingle < 0) {
      //     this.loseSingle = this.winSingle
      //     this.winSingle = 0
      // }
    }
  }
}
</script>

<style scoped>
.business-list {
  margin-bottom: 15px;
}
.business-label {
  display: inline-block;
  width: 100px;
}
.business-des {
  display: inline-block;
  color: #999;
  font-size: 12px;
  width: 60px;
}
.business-setting-content {
  border: 1px solid #e6e6e6;
  margin-top: 10px;
}
.business-setting-table-header {
  background: #f5f5f5;
}
.business-setting-table,
.business-setting-table-header {
  display: flex;
  text-align: center;
  height: 50px;
  line-height: 50px;
}
.business-setting-table-body {
  height: 250px;
  overflow-y: auto;
}
.business-setting-table > span,
.business-setting-table-header > span,
.business-setting-table > .el-input {
  flex: 1;
}
.business-setting-table > span > .el-input {
  width: 70%;
}
.business-setting-table > .icon-span > .el-input {
  width: 50%;
}
.business-setting-table > span .el-icon-circle-plus {
  color: #3e84e9;
  width: 20px;
  height: 20px;
  cursor: pointer;
}
.business-setting-table > span .el-icon-remove {
  color: #ff6767;
  width: 20px;
  height: 20px;
  cursor: pointer;
}
.business-setting-table:nth-child(2n + 1) {
  background: #f7f8fa;
}
.icon-box {
  width: 50px;
  display: inline-block;
  text-align: left;
  margin-left: 10px;
}
</style>
